LASER SCANNER WITH PARABOLIC COLLECTOR 



COMPUTER PROGRAM LISTING APPENDIX 
A computer program listing appendix containing the source code of a computer program 
that may be used with the present invention is incorporated herein by reference and appended 
hereto as one (1) original compact disk, and an identical copy thereof, containing a total of 473 
files as follows: 



LJQXQ oi i^reation 


iSize (Bytes) 


File Name 


iZ/ iU/ZUUi 


16,978 


ABOUT-l.CPP 


1 O / 1 A /O f\f\ 1 


19,800 


ABOUT-l.DFM 


1 o / I n /if\f\ 1 
iz/ lU/2UUi 


C 1 OA 

5,129 


ABOUT- l.HV 


Iz/lU/zOUl 


3,349 


ALERTF~1 .CPP 


Iz/ 10/2001 


21,014 


ALERTF-l.DFM 


12/10/2001 


3,551 


ALERTF-l.HV 


12/10/2001 


5,654 


ALERTL-l.CPP 


12/10/2001 


33,195 


ALERTL~1.DFM 


12/10/2001 


4,220 


ALERTL~1.HV 


12/10/2001 


13,605 


ALLLAN~1.RCV 


12/10/2001 


1,535 


ALLSPE~1.HV 


12/10/2001 


12,028 


ANCHOR-l.CPP 


12/10/2001 


4,968 


ANCHOR-l.HV 


12/10/2001 


15,707 


ASSEMB-l.CPP 


12/10/2001 


57,382 


ASSEMB-l.CPX 


12/10/2001 


4,453 


ASSEMB~1.HV 


12/10/2001 


10,034 


ASSEMB~1.HXV 


12/10/2001 


94,449 


ASSEMB~2.CPP 


12/10/2001 


16,442 


ASSEMB~2.HV 


12/10/2001 


1,845 


ASSEMB~3.HV 


12/10/2001 


21,077 


ATTACH-l.CPP 



1 9/1 0/9001 


7 77^ 


ATTAr'W^l 
/\i i/\^^rl~i,rlV 


19/10/9001 


^ 140 


ATTAr'W^I T?TTV 
/\1 — l.rvtlV 


19/10/9001 


^ 1 ^0 


ATTAP1^~0 


19/10/9001 


9 J?94 


RAT T Tn<~^1 PPP 


1 9/1 0/9001 


9 90S 


RAT T Tn.^1 T4\/ 


12/10/2001 


1 0'>4 


J->1 1 iVl/\x ~1 .IVV^ V 


12/10/2001 


1 55R 


RTTMAP—I PTTV 


19/10/9001 


1 410 


RT nR~1 TTV 
-DI^W-D i .rx V 


19/10/9001 


S 97^ 


ROT TTTF^l PPP 


19/1 0/9001 


^ 1 ^A 


ROT TTTF^l TTV 


1 9/1 0/9001 




Tjr^T Tur^ 1 r^DD 


1 9/1 0/9001 


0 07^ 
Z,Z / J 


JDiJi^ i rlij— 1 .rl V 




QA7 


TUT TTT TM^ 1 1U^7 

r> U ILL/ JJ~ 1 .rl V 


iz/ lu/zuui 




oUlLUl'^i.llV 


19/1 O/OOOI 
IZ/ lU/zUUi 




"DT TTT r^XT 1 TU'^r 

r> U ILUN'^ 1 .H V 


IZ/ iU/zUUl 


QQO 
OOZ 


CrlCjAl l'--l.CUK 


Iz/ lU/zUUi 


1,3 /o 


/^T TTT7 T 7 1 T/^/^ 


10/1 A/0AA1 
IZ/ iU/ZUUi 


^ oo< 

J5Z / J 


CULUKM--^ 1 .Crr 


10/1 A/0AA1 
IZ/ iU/ZUUi 


0 ylAI 


CULUKM— 1 .H V 


1 0/1 0/0001 
IZ/ iU/ZUUi 


OQ G/^Q 




1 9/1 0/9001 

iZ/ lU/ZUUl 


O'i /^'^l 


iJiN r ivj~ 1 . rl V 


1 9/1 O/0AO1 
IZ/ iU/ZUUi 




Ko UK--' 1 .KU V 


10/1 A/0AA1 
1 Z/ 1 vJ/ ZUU i 


1 A QQ 


C U UK~ 1 .Krl V 


10/1 A/0AA1 
1 Z/ i U/ ZUU 1 


< ^00 


U A i ALU— 1 . Lr r 


1 0/1 A/OAA1 

Iz/iU/zUUi 


1 ^ A /CO 


DATALU--1 .DFM 


10/1 A/0AA1 
IZ/ iU/ZUUl 


/I QylO 

4,o4z 


■pv A HP A T 1 T TX 7 

UAl ALO~l.HV 


12/10/2001 


5,032 


DATAL0~2.HV 


12/10/2001 


1,146 


DEFAUL-l.ICO 


12/10/2001 


3,257 


DEFLEC-l.CPP 


12/10/2001 


2,054 


DEFLEC~1.HV 


12/10/2001 


1,058 


DIMATT-l.HV 



19/10/7001 


J / 5 / / I 


T^TlV/fT A V 1 r^DD 


12/10/2001 




PiTA/TT AV 1 r^pv 


1 2/1 0/9001 


Q Q7^ 


JJUVlJL/\ 1 ~ jL .rl V 


12/10/2001 




niA/TT AV-^1 TTY\7 


12/10/2001 


14 ^OQ 


DT T PA/TFi^l PWV 
J-Vi^JLfV^iVijL/ — 1 .ivrl V 


12/10/2001 


00\J 


FiT T PTIP^I T?UV 


19/1 0/9001 

X Z,/ X \JI Z^\J\J X 






12/10/2001 

x^l x\Ji Z^KJxj X 


90 ^ 1 4 

ZU, J IH- 


T^T T T^T 1 
LJLiLjlJLj\j^ i , JlvM. V 


12/10/2001 

X^l X\Ji Z^\J\J X 




IJiu J^iVlliiN ~ 1 . Krl V 


1 2/1 0/2001 




jJJLi^o 1 K'~ i .ivrl V 


12/10/2001 


'^1 ^^^1 


0 i KlIN 1 . r Jr 


19/1 0/9001 

x^/ 1\J/ Z^KJyJ i 


1 ^ 1 Q8 


PWXT A "PiT 1 ODD 


1 9/1 0/9001 


9 9/^S 


L) Y JN AU1~1 .H V 


19/1 0/9001 


9 ono 


bA Viini'^l . 1 LB 


1 9/1 0/9001 
IZ/ 1 U/ZUUl 


J5O3O 


bD (jrbb P~ 1 . CFP 


19/1 O/OOOl 
iZ/ 1 U/ZUUl 


9 1 QQ 


bDCjbbr—l .H V 


1 9/1 0/9001 

iZ/ 1 U/ZWv/l 


1 9 09^ 




19/1 0/9001 
IZ/ lU/ZUUi 


'J /1 1 1 


T7XTT TA /TTT A 1 T 7" 


1 9/1 0/9001 

IZ/ lU/ZUVJi 




bJN U M W U~ 1 .Cr r 


1 9/1 0/9001 

IZ/ iVJ/ZUUl 


'J 990 


bN U M W U~ 1 .H V 


1 9/1 0/9001 
IZ/ 1 U/ZUUl 


1 ^ 


bKJKbJN U^l ,H V 


19/1 0/9001 
IZ/ 1 W/ZUUl 


A n^"! 
4, / 


bKKUKb—l .HV 


1 9/1 0/9001 

1 Z/ 1 U/ ZVJU 1 


1 9ftQ 


bor DA 1 — 1 .Cr r 


19/1 0/9001 
IZ/ iU/ZUUl 


1 72,40 / 


"COTTTN A TP 1 TXT" A /f 

bSr DA 1—1 .DFM 


19/1 0/9001 
IZ/ 1 Kit Z.KJ\J I 




bbrDAT— l.HV 


19/1 0/9001 
iZ/ lU/zuUl 




ESFDEF~1.HV 


12/10/2001 


23,781 


ESFEXP~1 .CPP 


12/10/2001 


7,095 


ESFEXP~1 .HV 


12/10/2001 


1,210 


ESFMSG~1.HV 


12/10/2001 


42,843 


ESF~1.BPR 


12/10/2001 


10,301 


ESF~1.CPP 



1 n / I A /on A 1 


A AA'3 

4,003 


libr — l.CrX 


1 O / 1 A /O A A 1 

iZ/ iU/ZUUl 


1 '7/1 


T7CIT7 1 J) r^\7 


IZ/ iU/ZUUl 


Jji jz 


T7QTTA/rA 1 r~^T)lD 

r^o 1 ilVi/V'^l .^^Jrr 


10/1 n/onni 

IZ/ lU/ZUUl 


iDjUoy 


T7QTT\/f A 1 FiT7A/f 
HjO i iiVi/V~ 1 . JJr iVL 


1 0/1 A/O AA1 

IZ/ iU/ZUUi 


4, /4/ 


1^0 1 ilVLA~l .rl V 


1 O / I A/O AA1 

1 Z/ i 0/ZUU 1 




bo 1 JN U 1 1 .Cr r 


1 O /I A/OAAI 
ill lU/ZUUi 


1 A 1 1 'V 

10,1 1 / 


bbl jNUl^l.DrJVL 


1 O / I A/OAA1 

IZ/ lU/ZUUl 


/I O^ A 


bo 1 JNUl — l.HV 


1 O / I A/OAA1 

1 Z/ 1 U/ZUU 1 


A 1 '2'7 


bArUKl~l. i Al 


1 O /I A/OAA1 

lZ/1 U/ZUU 1 




bAl~l.L.rr 


1 O /I A /OAA1 

iZ/lU/ZUUl 


45U0/ 


bAl^l.riV 


1 O / 1 A /O A A 1 

12/lU/zUOl 


0 AC ^ 
25955 


r AC 1 OR~l .CrP 


1 O /1 A /OA A 1 

12/10/2001 


0 1 A C 

2,345 


FACTOR-- 1 .H V 


12/10/2001 


/I All 

4,411 


FENDER— 1 .CPP 


1 O / i A /O A A 1 

12/10/2001 


2,800 


FENDER- 1 .HV 


1 O /1 A/OAA1 

12/10/2001 


1 A /I AO 

10,408 


MNDPO— l.CFr 


12/10/2001 


40,125 


FINDPO— 1 .DFM 


1 O /1 A /OA A 1 

12/10/2001 


A 0 AO 

4,302 


tlNDPO— l.HV 


1 O /1 A /OA A 1 

12/10/2001 


A A 

4,704 


FIXTUR-1 .CPP 


1 O /1 A/OAA1 

12/10/2001 


2,848 


T'TA.T'nr'T T"Pl 1 T TX 7" 

FIXTUR-l.HV 


12/10/2001 


2,637 


FbANGE~l .CPP 


1 O / I A/OAA1 

12/10/2001 


2,243 


FLANGE-l.HV 


12/10/2001 


6,328 


FRAME- 1. CPP 


12/10/2001 


3,785 


FRAME- l.HV 


12/10/2001 


0 0 ;T 

885 


FREEZE- 1. CUR 


12/10/2001 


8,459 


GARC-l.CPP 


12/10/2001 


3,723 


GARC~1.HV 


12/10/2001 


4,424 


GATTRI~1 .CPP 


12/10/2001 


2,869 


GATTRI~1.HV 


12/10/2001 


5,252 


GBLOCK-l.CPP 


12/10/2001 


3,774 


GBLOCK~l.HV 



-5- 





1 o /1 A/or^ni 


j,j2j 


LlUilvL^ i . r 




1 o /I A/onni 
Iz/iU/ZUUl 


2, J 1 1 


cxc^\\>c^^ 1 ua;' 

IjU1ivV^jL~ 1 ,rl V 




1 O / I A/O AA1 

lz/iO/2UUl 


0^2 A70 






1 O / I A /O AA1 




r^FM A T 1 T^T7A/r 


J 


1 O /1 A /O AA1 

12/ 10/2001 


2,o /o 


Tw r\ 1 \j\ J 
CjJJiAJuU— i .rl V 




1 O /I A /OAA1 

12/10/2001 


1 A 1 1 A 


r^TI?XT/^T^ 1 r^pp 




1 O / I A /OA A 1 

12/10/2001 


O 1 o^ 


vjiiiN K^Vj-^ 1 .rl V 




1 O /1 A /OA A 1 

12/10/2001 


1 ^ OA1 

lD,o01 


/^"CXT/^T T 1 T3PP 




1 O / I A /OA A 1 

12/10/2001 


4,5 io 


r^"DXTr^T T 1 r^PP 


1 A 

10 


1 O /1 A /OA A 1 

12/10/2001 


AOO 1 iCO 


r^lI?XT/^T T 1 rM7Ayr 

(jrh/JN UL1~ 1 .Ur JVL 




A'^ 1 /OAA1 

07/31/2001 


C AzT A 

5,960 


CjbJN CL1~ 1 .DbJv 


<■* 


1 O / 1 A /'^ A A 1 

12/10/2001 


13,351 


(jrliJNCLl^l .H V 




1 / 1 A /O A A 1 

12/10/2001 


5,395 


CjhN CL1~ 1 .KC V 


ly 


1 / 1 A A A 1 

12/10/2001 


3,976 


CjbJNCLl'-l .KHV 


'"aril ^ 
?;* s 


1 -O / I A /"OA A 1 

12/10/2001 


65,406 


(jrliJN CLl~2.Br K 




12/10/2001 


12,950 


GEN CL1~2 . CPP 


5 3 
■!!SSf 


1 / 1 A /'^ A A 1 

12/10/2001 


313,467 


/^HrXT/^T T O yf 

CjbJN CL1~2 .Ur M 




1 O / 1 A A A "I 

12/10/2001 


1 C AA 

1,599 


/^Tli'XTOT T O TUA r 

CjliJN CL1~2 .H V 


■:iiss" 


1 / 1 A A A 1 

12/10/2001 


1,317 


/^"C?T\.T/^T T 1 OUT* 


20 


1 O / 1 A /-O A A 1 

12/10/2001 


O 1 OCA 

ol,o50 


CjC/JN CL1~4. Cr r 




1 / I A/OAA1 

12/10/2001 


1 o o o 

1,338 


CjbNDbB--l .H V 




12/10/2001 


2,212 


GENDIA-1 .RHV 




12/10/2001 


46,616 


GENERA- 1 .CPP 




12/10/2001 


6,000 


GENERA- l.HV 


25 


12/10/2001 


17,734 


GENESI-l.CPP 




12/10/2001 


4,141 


GENESI~1.HV 




12/10/2001 


1,146 


GENESI~l.ICO 




12/20/2001 


1,720,807 


GENESI~1.ZIP 




12/10/2001 


3,103 


GENFON-l.CPP 


30 


12/10/2001 


2,562 


GENFON-l.HV 




12/10/2001 


12,713 


GENLAN-l.CPP 



-6- 





1 O /1 A /OA A 1 

12/10/2001 


3,284 


GbNLAN'-'l .HV 




1 O /1 A /O A A 1 

12/10/2001 


O ^ A 1 

2,701 


CjbNLAN~l .RCV 




1 O /I A /'^ AA1 

12/10/2001 


'7 0 AO A 

/O502y 


CjbJNrKb^l .Crr 




1 O / 1 A /'^ A A 1 

12/10/2001 


1 1 A /i O 

161,048 


(jbN rKb~ 1 .Dr M 


5 


1 O / 1 A A A 1 

12/10/2001 


13,858 


GENPRE- 1 .HV 




1 O / 1 A /O A A 1 

12/10/2001 


O A'^ 'J 

26,933 


(jrhN r Kh~2 . Lr r 




1 'O / 1 A A A 1 

12/10/2001 


A A 1 ^7 

9,017 


GENPRE-2 .HV 




12/10/2001 


120,:>27 


GENREG~1 .CP? 




1 / 1 A /'O A A 1 

12/10/2001 


27,352 


GENREG— 1 .HV 


10 


12/10/2001 


21,159 


GENRES- 1 .BPR 




1 /"I A /'O A A 1 

12/10/2001 


13,963 


GENRES'-- 1 .CPP 


? ■ s 


12/10/2001 


1,925 


GENRES- 1 .RCV 




12/10/2001 


79,115 


GENSER~1.BPR 




12/10/2001 


21,141 


GENSER-l.CPP 




12/10/2001 


20,323 


GENSER-l.DFM 




12/10/2001 


1,445 


GENSER-l.HV 




12/10/2001 


12,273 


GENSER-l.IDL 


5^ 


12/10/2001 


1,805 


GENSER-l.RCV 




12/10/2001 


3,347 


GENSER-l.RHV 


Ill 

20 


12/10/2001 


A J~\ F^ F^ 

74,033 


GENSER-1 .TLB 




12/10/2001 




GENSER-2.CPP 




12/10/2001 


1,313,086 


GENSER~2.DFM 




12/10/2001 


139,157 


GENSER~2.HV 




12/10/2001 


9,179 


GENSER-3.CPP 


25 


12/10/2001 


1,599 


GENSER-3.HV 




12/10/2001 


1,313 


GENSER~4.CPP 




12/10/2001 


22,937 


GENSER-^-HV 




12/10/2001 


174,323 


GENSER~5.CPP 




12/10/2001 


1,269 


GENSHA~1.HV 


30 


12/10/2001 


4,169 


GENSTA-l.RHV 




12/10/2001 


84,265 


GENSTR~1 .RCV 



1 o /I n/inni 
iZ/ iU/zUul 


Q OA/1 


/^TI?XTCTI) 1 


10/1 n/OAHl 
iZ/ iU/ZUUl 


1 A O/^O 


vjrI/iN V J:^K~ i .KU V 


10/1 n/onm 

IZ/ iU/ZUUl 


Q/: AO'S 


r^nrxTVDO 1 r^DT> 
UrJ^iSi AJr K~ 1 . V^rr 


1 0/1 A/onni 
IZ/ lU/ZUUl 


A OTO 

yjZ /z 


/^"CXTVOO 1 "LJ\7' 

Vjr/iN Ar 1 . rl V 


10/1 n/onni 

1 Z/ i U/ZUU 1 


'2 <IA^ 
JjJUO 




10/1 n/onni 

IZ/ i U/ZUU 1 


Z5J / J 


Lrr IJ^J^^i .xl V 


1 o / I A/onni 
iZ/ i U/ZUU 1 


'7 ^70 1 

/, /oi 


LrijrKArrl~l .Crr 


1 O / I A/O AA1 

lZ/1 U/ZUU 1 


'2 < 1 0 
J5JI0 


IjrLrKAr rl'^ 1 .rl V 


1 O / I A/O AA1 

IZ/lU/ZUul 


^2 OAA 


ijriN I:>h,K~ 1 .Cr r 


1 O /I A/OAA1 

1 Z/ 1 U/ZUU i 


0 /CI A 


(jrlN iSliK— 1 .H V 


1 O /I A/O AA1 

iZ/ 1 U/ZUU i 


1 /I 0 00 

145Z0Z 


r^T A vTiro 1 /^r>T> 
LrL A 1 t^Kr^ 1 . Cr r 


1 O /1 A /O AA1 

iZ/1 U/ZUU 1 


3,ZOO 


/^T A \/irr> 1 TLJ\7 

CjLA Y bK'^ 1 .H V 


1 O /1 A/O AA1 

iZ/lU/ZUUl 


0 o^n 


(aLUNii'^l .Crr 


1 O /1 A /OA A 1 

iZ/1 U/ZUU 1 


0 '5 AA 


/^T TXTTI? 1 1JI\7 

CjLUNn—l.HV 


1 O /1 A /OA A 1 

12/10/2001 


3,415 


GPAlH-l.CPP 


1 O /1 A /OA A 1 

12/10/2001 


0 /Cyl 1 

2,641 


CjrAlH'--l.HV 


1 O / I A /OA A 1 

12/10/2001 


j,700 


(jrUlN 1 --1 .Crr 


1 O /1 A/OAA1 

12/10/2001 


0 c 1 /I 

2,514 


GPOINT~l.HV 


1 O / 1 A /O A A 1 

12/10/2001 


5,979 


GPOLYA'--l .CPP 


1 O / 1 A /O A A 1 

12/10/2001 


3,120 


GPOLYA-l.HV 


12/10/2001 


1,925 


GPOLYF-LCPP 


12/10/2001 


2,017 


GPOLYF-l.HV 


12/10/2001 


2,820 


GPOLYL-l.CPP 


12/10/2001 


2,401 


GPOLYL-l.HV 


1 O / I A/OAA1 

12/10/2001 


1,903 


GPOLYO-l .CPP 


12/10/2001 


1,985 


GPOLYO~l.HV 


12/10/2001 


6,266 


GPOLYS-l.CPP 


12/10/2001 


2,859 


GPOLYS~l.HV 


12/10/2001 


3,401 


GRECT-l.CPP 


12/10/2001 


2,340 


GRECT~1 .HV 


12/10/2001 


2,434 


GRTYPE~1.HV 



1 o /I n/onni 

IZ/ iU/ZUUl 


^ 491 

0,H-Z1 


GSPAT F~l rPP 


10/1 nnnni 

IZ/ iU/ZUUl 


Z, Jt-Z 


V 1 f TV . /-\ 1 /I j~ 1 .11 V 


iZ/ 1 U/ZUU i 


^ 9Q7 


vJ kJ V-/.1 / 1 1 y 1 . V^l 1 


iZ/ lU/ZUU 1 


9 AHA 


vJOV-/-L^lJ--' I .11. V 


IZ/ lU/zUUl 




G^PFPD-.I PPP 


10/1 n/onni 
iz/ iu/zuui 


'X 1 9^ 
J), iZJ 


G^PFrn-^i HV 

vjox xj/v.-'j-/ i .n. V 


1 o /I n/onni 

IZ/ iU/ZUUl 


1 7^Q 
i J, 1 :>y 


fr^PFPT --1 CW 


1 O /I fi/OAAl 
IZ/ lU/ZuUi 


^ QQ1 




1 o /I n/onni 

iZ/ lU/ZUUi 


cLn C71 


OSPFPM--1 PPP 


1 o /I A/onni 
IZ/ lU/ZuUl 


1 9 ^^99 
IZ5JZZ 


OCPFPM~1 HV 


1 O / 1 A /O A A 1 

IZ/ lU/ZUUl 




O^PPPP-^I PPP 

VJO 1 Jj/V^l^'^ i . V^l 1 


1 O /I A/O AA 1 

IZ/iU/ZUUi 


1 1 'XA^ 


urKjJriZ/^j:^~i .n v 


1 O /I A/O AA1 

iZ/iU/ZUul 


1 7 Q 1 ^ 




1 O / I A/OAAI 

iZ/ lU/ZUUl 


1^1 


P^PFP'^s—l HV 


1 0/1 A/OAA1 

IZ/iU/ZUUl 


IZOjJZH- 


PQPFP^l PPP 


1 O / 1 n /O HA 1 


yo, / 


PQPPrP^I PPV 


1 O /I A/O AA 1 

iZ/ iU/ZUUl 


OA /CI 


Pl^QPPPr^l HV 


1 O /I A /OAA1 


OA ^'J/C 


Pi^QPT7P 1 TTYV 
VJoJ: i:!/l^~ i .itLal V 


1 O /I A/OAA1 

12/10/2001 


/in Q^n 


rW A CX^^ 1 PPP 


1 O / 1 A /O A A 1 

12/10/2001 




VJ 1 /VKvjri/^ i .rl V 


1 O / 1 A /O A A 1 

12/10/2001 




r^T" A p rf^T7-^ 0 r^PP 


1 /1 A /OA A 1 

12/10/2001 




CW A p r\x^ 0 i-r\/ 
0 X /\K.vjJ:l/~Z.rl V 


1 O / I A /OA A 1 

12/10/2001 


A AOA 


riT'Tirvx 1 r^pp 
Lr 1 xiA 1 ~ 1 .v^r r 


12/10/2001 


0 an c 

2,676 


/^T'T^VT" 1 TU\/ 

CjliiAl'^i.JnLV 


12/10/2001 


6,065 


vjl Yrii'--l.Crr 


12/10/2001 


5,21)1 


/^TVPr? 1 1U\7 

(jrl Yrii'--'l .rlV 


12/10/2001 


10,566 


GVEHIC-l.CPP 


12/10/2001 


2,341 


GVEHIC~1.HV 


12/10/2001 


25,287 


GVSPEC^l.CPP 


12/10/2001 


6,241 


GVSPEC-^LHV 


12/10/2001 


3,276 


HISTOR-^LCPP 



12/10/2001 




lUTQTrM> 1 \J\J 

rlio i UK'^ i .rl V 


12/10/2001 


7,yi / 




12/10/2001 






12/10/2001 


5,498 


rlUUJJ'^i .Urr 


12/10/2001 




HUU1J'~-'1.Jl1V 


12/10/2001 


1,065 




12/10/2001 


2,1 50 


rl U qVjOKJ'^ 1 .rl V 
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20 BACKGROUND OF THE INVENTION 

Field of the Invention 

The present invention is broadly concerned with apparatus for determining deformation 
in vehicle bodies and the like, using a laser scanning apparatus in conjunction with a plurality of 
coded targets suspended from (or m known relationship to) known reference points on the 

25 vehicle to calculate three dimensional spatial coordinates defining the actual positions of the 
targets, and to compare such calculated positions with manufacturer-provided specification 
values. More particularly, the invention is concemed with such apparatus and corresponding 
methods wherein use is made of a stationary central laser assembly including respective emitter 
lasers and corresponding parabolic collectors and associated detectors, a pair of upright, rotatable 

30 mirrors, and on-board scanner electronics all located within an enclosed housing. 
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Use of parabolic collectors has been found to enhance the detected signal strength, thus 
permitting more accurate vehicle repair. 

Description of the Prior Art 

In the past, vehicles such as automobiles have structural frames on which body panels and 
the like were built. Repair of accidental vehicle damage often involved straightening the frame 
and reshaping or replacing body panels. In order to meet government-imposed fuel consumption 
standards, unibody construction was adopted for many vehicles. In a unibody vehicle, no distinct 
frame exists apart from the body panels; instead, like an egg carton, the panels together form a 
"unibody", with consequence substantial weight savings. 

With either form of vehicle, frame or unibody, repair is greatly speeded with improved 
quality, by use of a frame (and unibody) straightening machine such as described in U.S. Patent 
No. RE 31,636. While such straightening machines are highly effective, such machines do not 
by themselves provide information as to the extent of straightening to be accomplished. Vehicles 
currently have manufacturer-provided reference points, such as reference openings or holes 
located at established points on the vehicles. Manufacturers also provide specifications for the 
correct three-dimensional spatial locations of these reference points relative to each other. Thus, 
if a vehicle is damaged, these reference points may be moved from their normal or "specifica- 
tion" positions with respect to each other. Most, if not all, vehicle frame and unibody 
straightening jobs require return of the vehicle reference points to within manufacturer 
specifications. 

U.S. Patent No. 5,801 ,834 describes a significant advance in the vehicle straightening art, 
and apparatus in accordance therewith has been commercialized by Chief Automotive Systems 
of Grand Island, NE. Specifically, this patent discloses a laser generating unit located beneath 
a vehicle and in an orientation for sweeping laser beams across the reflective surfaces of coded 
targets suspended from or in known relationship to the vehicle reference points. Preferably, a 
laser beam is split into two beams using a 50/50 beam splitter, with each beam then being 
directed to a rotating mirror. The rotating mirrors direct the laser beams in a 360 circle, with 
both beams being directed in a single plane. Each laser beam is reflected back to its source when 
it strikes the reflective stripes of the coded targets. These reflected beams are registered as "on" 
events (or counts) by the electronics onboard the laser measuring device. A counter coimts the 
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nimiber of coimts (as measured by an oscillator) from zero to the edge of each reflective/non- 
reflective border on the targets. An associated microprocessor receives the count information 
for each target and computes the angle from the center of each mirror to the center of each target. 
With the two angle measurements (one for each mirror and target) and the known baseline 
between the two mirrors, the planar (X, Y) coordinates of each reference hole are computed using 
trigonometry. The third coordinate (Z) is calculated using Z-coordinate representative sizing of 
the reflective and non-reflective strips on the coded targets. The actual three-dimensional spatial 
coordinates of each reference hole relative to a calculated point and plane are determined and 
displayed by the computer, along with the deviation from the normal or specification value 
provided by the vehicle manufacturer's data. With this information, the operator may then 
straighten the frame or vmibody, with successive measurements being taken to monitor the 
progress of the straightening operation and determination of when the frame or unibody is 

properly straightened. 

It will be appreciated that the system described in the '834 patent assumes that all of the 
vehicle targets will be essentially in plumb. However, in practice this is not always the case. For 
example, targets may not assume a plximb orientation owing to interference between the targets 
and vehicle components, particularly with damaged vehicles. Furthermore, many straightening 
shops are operated in open air so that the cantilever-suspended targets are subject to wind- 
induced oscillations. Whatever the cause, non-plumb targets detract from the desirable degree 
of accuracy which can be obtained using scanning laser devices of the type described in the ' 834 
patent. 

In response to this problem, Chief Automotive introduced an improved Velocity® 
scanner employing vertically spaced apart scanning laser beams, thereby permitting determina- 
tion of whether individual ones of the coded targets are in plxmib relative to the vehicle, and the 
extent of any target uiclination. This scanner is a decided improvement over single beam 
scanners. 

Generally, laser vehicle alignment scanning systems generate high frequency laser beams 
which are detected in an analog fashion by strategically placed detectors. A potential problem 
in such systems is the presence of ambient light which may interfere with proper detection of the 
desired high frequency laser beam(s). One strategy to avoid ambient Ught interference involves 
cutting off a lower frequency portion of the detected signal in an effort to eliminate ambient light 
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noise. However, this inevitably lowers the signal strength. As a consequence, a compromise 
must be made between signal strength and noise from ambient Hght interference. 

There is accordingly a need in the art for vehicle repair laser scanning apparatus and 
methods having improved detection devices which have increased signal to noise ratios. 

SUMMARY OF THE INVENTION 
The present invention overcomes the problems outlined above, and provides an improved 
laser scanning system, and correspondmg methods, for determining frame or unibody alignment 
of a vehicle. The system includes a scaiming apparatus together with at least one reflective laser 
beam target adapted for placement in a known relationship relative to a selected reference point 
on a vehicle to be scanned. The scanning apparatus has a laser assembly operable to direct laser 
beams toward the vehicle target, and corresponding detector assemblies for receiving reflected 
laser beams from the target. Preferably, the laser assembly is operable to direct a pair of 
individual laser beams spaced vertically from each other by a known distance toward the target, 
and to detect the reflected beams from the target. In this way, using a microprocessor operably 
coupled with the scanning apparatus, it is possible to calculate individual, upper and lower, three- 
dimensional spatial coordinates of the target using the respective vertically spaced apart laser 
beams. This in turn permits determination of whether the target is truly in plumb (i.e., vertical), 
and the extent of deviation from plumb for the target. A particular feature of the scanning 
apparatus is the use of detector assemblies each comprising a substantially parabolic reflective 
surface together with a strategically located radiation detector position substantially at the focal 
point of the reflective surface. 

In preferred forms, the laser assembly includes a pair of laser units, with each laser unit 
including a pair of vertically spaced apart lasers. The laser assembly is preferably stationary, 
with the overall apparatus including a pair of rotating mirror assemblies respectively located on 
opposite sides of the laser assembly. Each such mirror assembly comprises an upright mirror 
having a relatively wide reflective surface and a relatively narrow reflective edge; this permits 
discrimination between reflections from the wide mirror surfaces versus the narrow reflected 
edge surfaces. The detector assemblies advantageously include a block presenting an outboard 
paraboUc reflective surface with a pair of vertically spaced apart openings therethrough; the 
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associated upper and lower lasers are positioned so as to direct laser radiation through the block 
openings. 

In practice, a plurality of reflected targets form a part of the system, and are suspended 
from individual reference points on the vehicle. Each of the targets is mdividually coded so that 
the scaiming apparatus can discriminate between the targets. Preferably, each target has vertical 
endmost reflective stripes or "strikes", together with a pair of obliquely oriented reflective stripes 

between the endmost stripes. 

Preferably, the components of the scanning apparatus, and particularly the laser assembly, 
mirror assemblies, detectors and on-board electronics are housed within an enclosed housing. 
This assures that the scanning apparatus can be used in a shop environment with a minimum of 
contamination from ambient dust or the like. 

The parabolic detector assemblies give increased signal-to-noise ratios as compared wit 
conventional detectors, thereby giving improved aligimient accuracy. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Figure 1 is a side elevational view of a vehicle having coded reflective targets suspended 
from predetermined locations on the vehicle, and with the scaiming apparatus of the invention 
disposed below the vehicle and in an orientation for scanning of the depending targets; 
Fig. 2 is a front elevational view of the scanning apparatus; 

Fig. 3 is a sectional view taken along line 3-3 of Fig. 2 and depicting further details of the 
internal construction of the scanning apparatus; 

Fig. 4 is a vertical sectional view of the scanning apparatus; 

Fig. 5 is a bottom view of the scanning apparatus, with the bottom cover plate removed; 
Fig. 6 is a vertical sectional view taken along line 6-6 of Fig. 2 and depicting components 

of the laser assembly; 

Fig. 7 is a vertical sectional view taken along Une 7-7 of Fig. 2 and illustrating in detail 
the construction of the mirror assemblies of the scanning apparatus; 

Fig. 8 is an end elevational view of the scaiming apparatus, showing the on-off switch and 
computer connection for the scanning apparatus; 

Fig. 9 is an enlarged, fragmentary view with parts broken away and depicting the laser 
assembly and the associated parabolic collector and detector; 
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Fig. 10 is a perspective view of a preferred detector assembly in accordance with the 
invention, illustrating the paraboHc reflective surface and the detector located at the focal point 

of the reflective surface; 

Fig. 1 1 is a side elevational view with parts broken away of a target in accordance with 

the invention; 

Fig. 12 is a side elevational view of another target; 

Fig. 13 is a sectional view taken along line 13-13 of Fig. 1 1 ; 

Fig. 14 is a computer software flow diagram of the user program used to control the 
operation of the scanning apparatus in the field; 

Fig. 1 5 is a computer software flow diagram illustrating the vehicle measurement steps 

carried out during use of the scanning apparatus; 

Fig. 16 is a computer software flow diagram illustrating the base reference steps carried 

out during use of the scaiming apparatus; 

Fig. 1 7 is a computer software flow diagram illustrating the scanner read steps carried out 

during use of the scanning apparatus; 

Fig. 1 8 is a computer software flow diagram illustrating the target decoding steps carried 

out during use of the scanning apparatus; and 

Fig. 1 9 is a computer software flow diagram illustrating the target processing steps earned 

out during use of the scanning apparatus. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
Turning now to the drawings, and particularly Fig. 1, a vehicle 40 is illustrated on a lift 
device 42. The vehicle 40 has a plurality of individually coded targets broadly referred to by the 
numeral 44 suspended from specific locations around the vehicle. A factory precalibrated 
scanning apparatus 46 in accordance with the invention is located beneath the vehicle 40 and in 
an orientation for laser scanning of the suspended targets 44. As shown, the apparatus 46 is 
operatively coupled with a computer 48, typically in the form of a PC. 

The scanner 46 is illustrated in Figs. 2-10 and broadly includes a lower housing 50, an 
upper housing 52, a laser assembly 54, a pair of end-mounted mirror assemblies 56 and 58, a 
mam control board 60 and respective mirror assembly control boards 62 and 64 (see Fig. 5). 
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The lower housing 50 is in the form of a metaUic boxlike element presenting a front wall 
66, opposed rear wall 68, end walls 69 and 69a, top panel 70 and removable bottom plate 72. 
An elongated component compartment 74 is thus defined between front and rear walls 66, 68 and 
panel 70 and bottom plate 72. It will be observed (Fig. 8) that the end wall 69a is equipped with 
an on-off switch 76 as well as a pin-type connector 78 allowing coupling computer 48 to the 
apparatus 46. Bottom plate 72 is secured to the lower housing 50 by means of connector struts 
79. 

Upper housing 52 includes a top wall 80 with oblique, depending end walls 82 and 84. 
The upper housing 52 is secured to the lower housing 50 by means of end connectors 86 (Fig. 
5). The overall upper housing 52 also includes a pair of upstanding, opposed transparent glass 
window panels 88, 90 which extend substantially the full length of the upper housing between 
end walls 82, 84. Referring to Figs. 6 and 7, it v^U be seen that the panels 88, 90 are housed 
wdthin elongated grooves 92, 94 provided along the length of top panel 70, as well as within 
grooves 96, 98 provided along the underside of top wall 80. 

The laser assembly 54 is located within upper housing 52, and rests atop panel 70 of 
lower housing 50. The laser assembly 54 includes an upright housing cover 100 with a pair of 
oppositely directed, vertical dual laser units 1 02 and 1 04 therein. Each of the units 1 02, 1 04 has 
an upright circuit board 106, 108 equipped with electrical connectors 110, 112 as well as 
corresponding detector assembUes 1 14, 116. Additionally, the units 102, 104 have an upright 
mounting block 11 8, 120 which are secured by fasteners (not shown) to top panel 70. The blocks 
1 18, 120 support a pair of vertically spaced apart laser diodes 122, 124 (support 118) and 126, 
128 (support 120). The upper lasers 122, 126 are vertically spaced above the lower lasers 124, 
1 28 by a known distance (e.g., 3 1 mm); the upper lasers emit radiation in a common upper plane, 
while the lower lasers emit radiation in a common lower plane, where the planes are vertically 
spaced apart the same known distance. 

It will be observed that the blocks 118, 120 each have a corresponding outermost 
parabolic reflective surface 1 18a and 120a, as well as a pair of vertically spaced apart, oblong 
openings 130 (block 1 18) and 132 (block 120). Further, the inner faces of each of the blocks 
118, 120 have recesses 134 (block 118) and 136(120) which are in registry with the correspond- 
ing openings 130, 132. As illustrated in Fig. 9, the respective diodes 122-128 have outwardly 
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prqjections received within the block recesses. The preferred laser diodes emit 250 nm visible 
laser radiation. 

The detector assembly 114 includes, in addition to reflective surface 1 1 Sa, a detector 1 1 4a 
which is located substantially at the focal point of the surface 118a. The detector 114a is 
supported by means of a pair of laterally spaced apart, outwardly extending arms 137 and 
crosspiece 137a, A transparent cover 137b is secured to crosspiece 137a and is in covering 
relationship to detector 1 14a as shown (Fig. 9). The detector 1 16 is identical to the assembly 
114, and like reference numerals have therefore been applied to this structure. 

The mirror assemblies 56, 58 are mounted within and adjacent the ends of the upper 
housing 52. These assemblies are identical and therefore only assembly 56 will be described in 
detail. Referring to Figs. 4, 5 and 7, it will be seen that the assembly 56 includes a rotatable hub 
138 supporting an upstanding, planar, front reflective-surfaced mirror 140; the mirror 140 is 
silvered on one broad face 142 thereof, as well as along one narrow, waist-cut beveled edge 1 44. 
This beveled edge produces a secondary narrow mirror used to generate accurate synchronization 
signals. The edge is formed by grinding a precise waist cut radius and coating the edge so that 
edge-reflected laser beams are caused to strike back at the midpoint between the upper and lower 
lasers, namely at the detectors 1 14, 116. The radius cut is also at a bevel angle that permits the 
full thickness of the mirror to be centered on the laser beam at the precise angle which will reflect 
the beam toward the associated detector. 

As shown, the hub 138 is mounted within an opening 146 provided in top panel 70 of 
lower housing 50. The hub 138, and thus mirror 1 40, are rotated by means of a brushless electric 
motor 148 and a drive shaft 150 coupled to hub 138. The hub motor 148 is mounted on a three- 
point suspension to allow the mirror 140 to be adjusted mechanically to spin at a true vertical 
axis parallel to the other mirror. While these adjustments can be made mechanically, it can be 
difficult to obtain an exact alignment. Further, the internal rotating parts of the apparatus 46 are 
protected by the glass panels 88, 90 which may distort the rotational velocity of each hemisphere 
of scan due to the dissimilar index of refraction between the glass and air. A mathematical 
correction algorithm is applied by the post-computer 48 to correct all data for these potential 
aberrations. 

The rotational velocity of each motor 148 is controlled to produce a torque-ripple of less 
than 1 0 ppm of rotation speed. The motor 148 and control board 62 (Part No. RMOTN2028GE- 
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ZZ from Sharp Electronics) are supported beneath top panel 70 by means of a mounting block 
149 and three connector bolts 152 extending downwardly from panel 70. Each of the bolts 152 
carries a compression spring 154. 

The main control board 60 is situated below laser assembly 54 and is secured to the 
underside of top panel 70. An electrical connector 156 extends upwardly from board 60 through 
an opening 158 in panel 70, for electrical connection with connectors 1 10, 1 12 associated with 
the laser units 102, 104. The main control board includes appropriate electronics for software 
control of the laser assembly 54, 

Each of the mirror control boards 62, 64 includes Hall-effect sensor 160, 162 as well as 
other conventional electronics including a magnetically encoded tachometer ring used in the 
control of the respective mirror assembUes 56, 58. This provides a motor tachometer signal that 
is amplified to produce a square wave signal. This signal transitions high to low at one degree 
increments, providing 360 pulses per revolution of the motor. The speed control signal to the 
motor is generated by triggering a one-shot pulse of precise duration. The one-shot is 
implemented digitally, using the system clock running at 29 MHz by dividing the clock down to 
generate a precise millisecond pulse. The pulse is used to switch a reference voltage into a low- 
pass filter. The output of the filter rises in voltage when the speed of the motor is too slow, and 
drop in voltage if the speed of the motor is too fast. In this way, the motor speed is controlled 
to a precise rpm. A feedback loop is used to stabilize the rotational speeds of the motors at 
respective, constant speeds. This produces hub rotational velocities which are constant. 
Although not shown, the main control board 60 and mirror control boards 62, 64 are electrically 
connected by appropriate cabeling. 

Figs. 1 1 and 13 depict a typical coded target 44, which includes an elongated reflective 
body 164 with opposed end caps 166, 168. The body 164 is somewhat trapezoidal in cross- 
section as best seen in Fig. 13, and has a reflective face 170. In the illustrated target, a total of 
four upright, elongated mirrored reflective stripes 172, 174, 176, 178 are provided (sometimes 
referred to as ''strikes"), with non-reflective regions 179 therebetween. It will be observed that 
the reflective stripes 172 and 178 are vertically oriented at known slopes and are considered 
reference stripes. The intermediate stripes 174 and 176 (center strikes) are obUquely oriented so 
that the non-reflective distance between the intermediate stripes and the reference stripes varies 
throughout the height of the target. An upper hanger element 180 is secured to body 164 and 
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permits suspension of the target from a selected automotive location. Fig. 1 2 illustrates a hanger 
44 of a different length as compared with that illustrated in Figs. 1 1 and 13. However, the Fig. 
12 hanger likewise includes a body 164, end caps 166, 168, hanger element 180 and reflective 
surfaces 172-178. It will be appreciated that different targets 44 have different patterns of 
reflective surfaces thereon so that the scanner 46 may discriminate between individual coded 
targets, i.e., each target has a unique set of strike widths for the four strikes. Moreover, each 
target has an individual identification numbers associated therewith. The following criteria are 
used with the targets 44: minimum strike width, 2 mm; each strike width is at least 1-1/2 mm 
wider than the next narrowest strike width; minimum non-reflective gap between strikes, 3 mm; 
the targets should be relatively narrow so as not to block the view of other targets; and the targets 
are configured for use with a single-line scanner to measure target heights over a range of ±75 
mm. 

As delivered from the factory, the apparatus 46 is precalibrated to account and 
compensate for inevitable manufacturing tolerance errors and the like, e.g., nonvericality of the 
mirrors 140 and actual rotational speeds of these mirrors. Such factory calibration is carried out 
ushig a calibration program explained below and fully set forth in the source code appendix. The 
calibration parameters (52 in number) are stored in the nonvolatile memory of the apparatus 46 
and are recalled during the course of actual use of the scanner. 

In use, the scanning apparatus 46 is positioned beneath the vehicle 40 in an orientation 
such that the radiation emitted by the laser assembly 54 will strike the reflective faces of the 
coded targets 44 suspended from vehicle reference points. As illustrated in Fig. 1, this is often 
accomplished by placement of the apparatus 46 beneath the center region of the vehicle on the 
lift device 42. The computer 48 is coupled with the apparatus 46 as shown. 

During scanning operations, the mirrors 140 are rotated at determinable but slightly 
different (e.g., 1%) speed (e.g., 390 rpm) while the laser assembly 54 is operated. Specifically, 
the upper lasers 122, 126 are operated simultaneously and the lower lasers 124, 128 are also 
operated simultaneously. However, the upper and lower laser pairs are operated alternately 
owing to the fact that only a single detector assembly 1 14 or 1 16 is used. It will be appreciated 
that the laser beams emitted by the diodes 122-128 pass through the associated block openings 
130 or 132. During operation of the upper laser pair, a 360° scan is generated so that the 
reflective faces of each of the targets 44 is scanned. The radiation reflected from the targets 44 
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impinges upon the mirrors 140 and is reflected toward the parabolic surfaces 1 18a, 120a, this 
being illustrated by arrow 1 8 1 (Fig. 9). the parabolic surfaces are operable to reflect the radiation 
towards the focal point of the surface, where the detectors 1 14a, 1 16a are located. It will be 
appreciated that each sweep of every target generate eight on-off (reflective/non-reflective) 
events; the first and last of those events ~ the leading or "on" edge of the first reflective reference 
stripe, and the trailing "off of the last reflective reference stripe - are of special significance 
in the determination of target position, as will be explained. 

Furthermore, as the mirrors 140 rotate, light is reflected not only from the broad mirrored 
surfaces 1 42, but also from the narrow edge surfaces 1 44. The difference between broad face and 
edge radiation can be detected because of the intensity of light at the detector; the more intense 
light denotes edge-reflected radiation, whereas less intense light denotes broad face-reflected 
radiation. Hence, as the mirror rotation occurs, at some point for each target, the edge radiation 
will be detected; this is deemed tiie zero position. The next time edge radiation is detected, it is 
known that the mirror has traversed 360 ° . The time between the zero and 360 positions divided 
by 360 gives the travel time per degree of arc. 

Inasmuch as the distance between the mirrors 140 is known, measurement of the angles 
between each respective target and the mirrors 140 allows calculation of upper X, Y coordinates 
for each of the targets. Such calculations involve simple triangulation trigonometry, as explained 
in Patent No. 5,801,834 incorporated by reference herein. As the upper laser pair scans each 
target 44, the vertical position of the scan on the target is ascertained by determining the time 
between reflections from the reference stripe 172 and 178 and intermediate, oblique stripes 174 
and 1 76. For example, and considering Fig. 1 1 , a scan from left to right would generate different 
non-reflective times depending on the vertical location of tiie scan. With this information, and 
knowing the distance between die vertical position of tiie scan and the tip of hanger element 1 80, 
the upper Z coordinate for each target is calculated. 

After tiie scan by the upper lasers 122, 126, the lower lasers 124, 128 are operated in the 
same manner, to achieve a 360 scan of the targets 44. Again, tiie lower lasers permit calculation 
of a lower X, Y and Z coordinate for each of the targets. Of course, if the distance between the 
upper and lower Z coordinates for a given target equals the distance between the upper and lower 
lasers, that target is deemed to be essentially in plumb. 
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In practice, the upper and lower X, Y and Z coordinates for each target are averaged and 
these average X, Y, Z coordinates are used for determining the extent of frame or vehicle 
straightening required. Also, a vector is generated between the upper and lower X, Y and Z 
coordinates for each target, and the divergence of this vector from vertical can be used to 
determine the angle of inclination of the target. 

Figs. 14-19 are flow diagrams illustrating the preferred scanner driver software (the user 
program) which is employed by the actual user of apparatus 46 in the field. The user program 
software is resident on the computer 48 coupled with the apparatus 46. 

Turning first to Fig. 14, the main program flow is depicted. The user initiates the 
program at step 800, whereupon in step 802 the configuration for the system is loaded; this 
includes user preferences such as language and scanner type, and the calibration parameters 
derived from the factory calibration program and resident in the scanner's nonvolatile 
memory. Next, in step 804, the main screen is displayed which permits entry into all aspects 
of the program via a main menu. In step 806, the main form command loop is initiated 
which includes step 808. If no user input is detected, the program loops back to step 806. 
If such input is detected, the program proceeds to step 810 where a work order request query 
is carried out. If there is no work order request, the program proceeds to step 812 and seeks 
any other menu request. If there is no such menu request, the program proceeds to step 814 
where a quit operation query is performed allowing the user to quit the program in step 816. 
If the answer in step 8 1 4 is NO, the program proceeds to step 818 where the command loop 
is terminated and the program loops back to step 806. Reverting back to step 812, if the 
answer is YES, the program processes the menu request in step 820 and proceeds to step 
818. 

Returning to step 810, the work order request query, if the answer is YES, the 
program executes a shop management server (SMS) program 822. A cancel query is made 
in step 824, so that if the answer is YES, the program reverts to step 804. If the answer is 
NO, in step 826, work order and vehicle information are requested from the shop 
management server. Once this step is completed, the program proceeds to step 828 where 
vehicle information is loaded. This comprises a specification file and graphic for the 
individual vehicle being measured. Next, in step 830, a recall query is performed. If the 
vehicle in question was previously measured, that information would be in computer 
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memory. In such a case, the stored information is recalled via program 832, and the 
program then loops back to step 804. If the answer in step 830 is NO, the program proceeds 
to vehicle measurement program 834, which includes program A, Fig. 15. 

Referring to Fig. 15, there are three measurement modes to be considered - initial, 
repair of final measurements. The program initiates with step 836, a scanner initialization, 
followed by a new order query in step 838. If the answer at step 838 is NO, the program 
proceeds to step 840 where the measurement session is restored and the program proceeds 
to step 842. If the answer at step 838 is YES, meaning that an initial measurement is 
desired, the base reference program 844 is initiated. Fig. 1 6 later to be described. After the 
base reference is established in program 844, the program goes to step 842 where an initial 
measurement query is made. If the answer is YES, the program proceeds to step 846 where 
an initial measuring setup is made. If the answer is NO, meaning that there was a previous 
measurement, the program proceeds to step 848 which is a final measurement query. If the 
answer is YES, in step 850, the system is set up for final measurement. If the answer is NO, 
the program proceeds to step 852 to set up the repair measurement mode for the vehicle, i.e., 
where the apparatus 46 is used during actual frame or vehicle straightening to monitor the 
course of the repair. In either case, from steps 850 or 852, the program in step 854 enters 
the measurement loop. This involves in step 856 a measurement requested query. If such 
a request has been made, the program proceeds to the target processing program 858, Fig. 
19, If the answer at step 856 is NO, another menu request query is performed in step 860. 
If the answer at this step is YES, user input options are processed in step 862 and the 
program proceeds to the end measure loop 864. If the answer at step 860 is NO, the 
proceeds to step 866, a quit measuring query. If the answer at this step is YES, the program 
returns. If the answer is NO, it proceeds to loop 864. 

The base reference program is illustrated in Fig. 16. It will be appreciated that 
initially the apparatus 46 determines the position of the targets 44 relative to the apparatus 
itself using an internal coordinate system. However, the targets are also located with 
reference to the manufacturer's specification, using a different coordinate system. In the 
base reference software routine, the two coordinate systems are brought together, usually 
using four targets located about the central region of the vehicle. 
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This involves, in step 868, an initial display of the targets seen by the scanning 
apparatus 46 using the internal coordinate system. Next, a loop 870 is entered where, in step 
872, the user is allowed to match using manual inputs the targets seen by the scanner to 
corresponding vehicle manufacturer-provided specification points. Once this is accom- 
plished, the programs proceeds to step 874 which is a cancel query. If the answer is YES, 
the program proceeds to return 876. If the answer is NO, a job done query is made at step 
878. If the answer at this step is NO, the program proceeds to a menu option query at step 
880. If no option is selected, end loop step 882 is entered, and the program reverts to step 
870. If at step 880 the answer is YES, in step 884, the selected menu option is processed 
and the program proceeds to loop 882. 

Returning to the done query at step 878, if the answer is YES, the program in step 
886 fits the base targets to the manufacturer' s specification points, and the program proceeds 
to the target processing program 858, Fig. 1 9. This involves, to the extent feasible, adjusting 
the two coordinate systems so that the origins thereof are coincident. 

In the Fig. 19 target processing program, the first step is to read the scanner 
information via program 890, Fig. 17. After this is accomplished, a scanner reading query 
is made in step 892. This involves a determination as to whether the scanner readings are 
within predetermined limits designed to confirm the validity of the scanner readings. If the 
answer at step 892 is NO, the program proceeds to the return at step 894. If the answer at 
step 892 is YES, in step 896 there is a query to determine whether the base reference is 
valid. Again, this involves a determination of whether the base reference is within 
predetermined limits. If the answer at step 896 is NO, the program enters the reset base 
reference program 898, Fig. 16 described previously, and a new base reference is 
determined. If the answer is YES, the program proceeds to step 900 where the target 
positions ascertained by the scanner are transformed using the base reference. Next in step 
902, the program "attaches" the valid targets and "detaches" moving or invalid targets. This 
involves comparing the transformed target data with the specification data. If these are not 
matched, the specification is searched for possible matches within 50 mm. If this cannot be 
done, the target is deemed detached. If a target was attached in the previous meeisurement, 
the new position is compared with the previous one. If the difference is 30 or more mm, the 
target is considered "moving" and is detached. Thereupon, in step 904, an unplaced targets 
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query is made. If there are no unplaced targets, an unplaced target dialog screen is displayed 
(step 913) and the user is allowed to place targets via manual inputs. Thereafter, in step 906, 
a three point recommendation query is made. If the user elects to use the three point 
method, which involves establishing a base reference using the best three of four base 
reference measurements, a three point dialog is displayed in step 908. use of the three-point 
method may be selected if one of the 4-base reference points is adjacent a damaged region 
of the vehicle for example. Next, in step 9 1 0, a three point reference request query is made. 
If the answer is NO, the target positions are displayed and the program proceeds to retum 
894. If the answer is YES, the previous base reference is invalidated (step 912), and the 
program proceeds to retum 894. 

As described previously, in step 890, the read scanner program is executed. Fig. 17. 
This involves an initial query in step 914 to determine whether the scanner has been 
calibrated. If the answer is NO, the program in step 916 requests stored scanner version and 
calibration data from the scanner and proceeds to step 918 where a response error query is 
made. If the answer at step 918 is NO, the program reverts to the YES leg of step 914. If 
the answer at step 918 is YES, the program proceeds to step 920 where the fined scanner 
dialog is displayed. Thereafter, a retry communication query is made in step 922. If the 
answer is YES, the program returns to initial step 914. If the answer is NO, a display error 
screen is generated in step 924. 

Retmning to step 9 1 4, if the answer to the scaimer calibration query is YES , the next 
step 926 requests a scanner measurement involving a 360 sweep by the upper and lower 
laser pairs. The data received from this measurement is stored in buffer in step 928, This 
data is in the form of "event times" generated during scanning. In particular, the program 
considers each of the lasers as a "hub", there being an upper left, lower left, upper right and 
lower right hub. Moreover, as explained previously, each sweep of each target generates 
eight on-off reflective events. Thus, the buffer collects a series of encoded events during 
a measurement sweep, each event encoded into 32 bits of information. This information 
defines the type of event, e.g,, "on", "off, 0/360° edge reflection (synchronization pulse) 
or broad mirror panel reflection, or stray reflections. The information also represents the 
time the event occxirred during the measurement sweep. That is, each event is "time- 
stamped" as it occurs. The time base is a free-running coxmter that counts down the 29 MHz 
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clock. There are 25 bits in the counter, so the counter rolls over about once per second. 
This is adequate to uniquely timestamp every event that can occur during a scan. 

Scanning is started when the apparatus 46 receives a scan command from computer 
48. When this signal is received, a timestamp latch is armed to begin timestamping events 
for each hub, stalling with the next occurring edge reflection for that hub. From this point 
on, whenever an event occurs, a precise system time is recorded as 25 bits in a 32-bit latch. 
The remaining seven bits are used as "tag" bits that identify the exact conditions causing the 
event. The latched information is immediately saved in a first-in-first-out buffer, and the 
process is continued until each of the four hubs has collected data. At this point, the buffer 
contains four complete scans, and should contain eight leading edge and eight trailing edge 
reflection events. Each of these synchronization pulses marks the start or end of a complete 
hub scan. As soon as scanning is complete, the entire buffer is downloaded back to the 
computer 48 as a binary stream of 8 -bit bytes using an UART transmitter. 

After this event data collection, in step 930, a response error query is made. If the 
answer is YES, the program reverts to step 920. If the answer is NO, an event sorting loop 
932 is entered. In this loop, an all events processed query is made, step 934. If all of the 
events were stored in buffer, the program proceeds to the target decode program 936, Fig. 
1 8. If all events are not processed, in step 938 the hub identifications are decoded together 
with event types and times, the latter being sorted to individual hubs in the buffer. After 
step 938, a query is made in step 940 as to whether the scanning information is correct. For 
example, if there is an invalid target or insufficient data has been gathered, the answer at 
step 940 would be NO, and the program would revert to step 926 for another measurement. 
If the answer at step 940 is YES, end loop 942 is entered. 

The target decode program. Fig. 18, involves a hub decode loop 944 wherein hub 
motor speeds are calculated, step 946, as explained previously. In order to make this 
calculation, the zero and 360° synchronization times for each mirror are retrieved from the 
buffer. Once the motor speeds are calculated, the target decode loop is begun, step 948. 
The decode loop includes in step 950 the obtention of the next eight 4-byte event data 
packets for each target as the mirrors rotate. As explained above, each target has four 
reflective regions. As the laser radiation sweeps each target, there are a total of eight events, 
namely the times at which the radiation strikes the leading and trailing edges of each of the 
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four reflective regions. After step 950, a valid target query is made in step 952. This 
involves determining whether the eight events defining the four reflective regions 
correspond to a valid target code. If the answer is NO, the program in step 953 discards the 
first two of the eight recorded events and loops back to step 950. This continues until a 
valid target answer of YES is obtained in step 952. When this occurs, the program moves 
to step 954 where the target identification is decoded and the sweep height on each target 
is calculated using the times between events as mentioned previously. This gives the Z axis 
coordinate for each target. Also, the first and last reflective events for each target are 
converted to angles using the synchronization times. These results are then stored and the 
program moves to the end target decode loop 956 and end hub decode loop 958. 

hi this sequence, in step 960 each of the four hubs is compared to match decoded 
targets, i.e., hub and target data are matched. Next, in step 962 a query is made as to 
whether consistent target information has been obtained, that is, whether the hubs and 
targets have been correctly matched. If the answer is NO, a retum error step 964 follows. 
If the target information is consistent, the program proceeds to step 966 where each of the 
targets is triangulated relative to the mirrors 140 of apparatus 46. Specifically, four angles 
are known for each target: the angles between the leading edge of the first-swept vertical 
stripe (the first "on" event) and the two mirrors 140; and the angles between the trailing edge 
of the last-swept vertical stripe (the last ''off event) and the two mirrors 140. Therefore 
four triangulation calculations are made for each target, an upper pair of triangulations using 
the angles representative of the first "on" and last "off events from the upper laser sweep 
and a lower pair of triangulations likewise using the angles representative of the first "on" 
or last "off events fi:om the lower laser sweep. Thus, in step 968, the lower level laser 
sweep data is employed to generate and store in memory two lower X, Y, Z coordinates for 
each target. Similarly, in step 970, the upper level laser sweep data is employed to generate 
and store m memory two upper X, Y, Z coordinates for each target. Next, in step 972, a 
determination is made as to whether the stored target coordinates are consistent, i.e., whether 
the upper and lower coordinates are within predetermined limits. If the answer is NO, the 
program proceeds to return error step 964. If the coordinates are within limits (dependent 
chiefly upon the vertical distance between laser pairs), the upper and lower coordinate pairs 
for each target are averaged, and these upper and lower coordinate averages are again 
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averaged to yield a final X, Y, Z coordinate for each target. This final coordinate is stored 
in step 974. Also, the program generates a vector using the upper and lower coordinates for 
each target, these vectors being used to ascertain the target hang angles which are also 
stored. This being done, in step 976, the triangulation loop is terminated and a successful 
measurement is completed. 

As explained previously, each scaiming apparatus 46 is factory precalibrated. 
Generally speaking, this calibration is carried out using an optical bench having a plurality 
of targets 44 spaced around the bench at precisely known locations. An individual apparatus 
46 is placed in the middle of the bench with a coupled computer 48, and is operated to scan 
the targets as described above. This generates a series of apparent target positions using the 
uncalibrated apparatus 46. These target locations will typically be in error to a greater or 
lesser extent, as compared with the known position of the targets, owing to slight 
manufacturing tolerance errors, e.g., in the position and spacing of the lasers 122, 126 and 
124, 128, or in the orientation of the mirrors 140. 

Next, the calibration program undertakes an iterative, non-linear fit to an empirical 
trigonometric equation, and generates coefficients for this equation which give the best fit. 
This equation is: 

RealAngle - a + ALL + BLL x sin (1 x a + DLL) + 
CLL x sin (2 x a + ELL) +FLL x sin (3 x a + GLL) + HLL x sin (4 x a + ILL) 
where ALL, DLL, ELL, GLL and ILL are angle corrections as lead/lag offsets for each of 
the fiindamental, first harmonic, second harmonic, third harmonic and fourth harmonics (as 
denoted by the multipliers 1, 2, 3 and 4), and BLL, CLL, FLL and HLL are the respective 
magnitude multipliers for each harmonic. The above equation applies these coefficients so 
as to correct the observed angles a to correct angles. 

As a part of this procedure, the program completes a conventional mean squared 
error (MSE) calculation in order to produce coefficients for the trigonometric equation 
giving the lowest possible MSE. Once these coefficients have been determined, they are 
saved in an INI formatted file in the scanner' s non-volatile memory, and can be retrieved for 
use when the apparatus 46 is used in the field, as described above. 

Additionally, the calibration program employs another equation to correct for pitch 
angle of the laser beams as they vary during a full 360"" scan. This equation makes a minor 
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correction to the observed target height; this height correction gets larger as targets further 
from the scanner are scanned, because the beams are pitched up/down owing to, e.g., a tihed 
mirror. The pitch angle calibration equation used is: 

Pitch angle = AP + BP x sin (a + DP) 
where AP is the average pitch angle (laser beams drawing cones), DP is the phase, BP is the 
magnitude of a tilted plane and a is the rotational angle to the target. Accordingly, the true 
height of each target is expressed by the equation: 

True height = H + sin (Pitch angle) 
where H is the observed height for the target. The coefficients generated by this calculation 
are also stored in memory. 

The calibration program is reproduced in its entirety in the attached source code 
appendix. 

The use of detector assemblies in accordance with the invention including 
substantially parabolic reflector surfaces together with detectors mounted substantially at 
the focal points of the parabolic surfaces yields a nxmiber of significant advantages. Most 
important, detector assemblies of this type give improved signal-to-noise ratios owing to the 
fact that a higher proportion of the laser radiation is collected as compared with the use of 
simple focusing lenses and detectors. As a consequence, the laser scanning systems of the 
present invention give more accurate alignment information, thereby facilitating vehicle 
repair. 

While in the preferred embodiment described above, use is made of a total of four 
laser diodes 122-128, two vertically spaced diodes 122, 124 and 126, 128 on the respective 
supports 118 and 120, the invention is not so limited. For example, only two diodes may 
be used, one moxmted on each of the supports 118, 120, if desired, along with the preferred 
parabolic detector assemblies. Such a two-diode design in many instances will give 
sufficiently accurate scanning data, although the preferred four-diode design can give greater 
accuracy and the ability to compensate for out of plumb targets. 



